## **CLAIMS**

What is claimed is:

| 27/ | <b>}</b> 3 |
|-----|------------|
| 200 | ハン         |

4

5

6

58 51 51

102

<u>ال</u>الا الالا

ľIJ ť.O

5

6

7

1

1. Method comprising:

providing a first taken/not-taken prediction responsive to an address using a
saturating counter branch predictor;

providing (1) a second taken/not-taken prediction responsive to the address resulting in a hit in a local branch history table, and (2) a hit/miss indication for the address; and

selecting for the address one of (1) the second prediction if the indication is a hit, and (2) the first prediction if the indication is a miss.

2. The method of claim 1 further comprising:

hashing the address prior to indexing at least one of the saturating counter branch predictor and the local branch history table.

3. The method of claim 1 further comprising:

updating a replacement field for a matching entry in the local branch history table only if the first prediction is incorrect, indicating that the entry is used to make a prediction.

- 4. The method of claim 1 further comprising:
- 2 fetching at least one instruction at the address; and
- decoding the at least one instruction, wherein at least one of the first and second
- 4 predictions is available when the at least one instruction is being decoded.

| 1                | A3 5. The method of claim 4 wherein the at least one instruction is a branch, the              |
|------------------|------------------------------------------------------------------------------------------------|
| 2                | method further comprising.                                                                     |
| 3                | determining a target address of the branch; and                                                |
| 4                | loading an IP generator with the target address if at least one of the first and               |
| 5                | second predictions indicates that the branch is to be taken.                                   |
| 1                | 6. A processor comprising:                                                                     |
| 2                | an instruction pointer (IP) generator capable of providing an address;                         |
| 3                | saturating counter branch prediction (SCBP) logic having an input coupled to th                |
| 134              | IP generator and capable of providing a first taken/not-taken prediction at an output          |
| 145<br>1,11      | responsive to the address;                                                                     |
| 5<br>116         | local branch history prediction (LBHP) logic having an input coupled to the IP                 |
| <sup>1,Π</sup> 7 | generator and capable of providing (1) a second taken/not-taken prediction at an               |
| 18<br>9<br>0     | output responsive to the address resulting in a hit, and (2) a hit/miss indication for the     |
| <b>1</b> 9       | address; and                                                                                   |
| 10               | a multiplexer having an input coupled to the outputs of the SCBP and LBHP                      |
| 11               | logic and a select input coupled to receive the hit/miss indication and in response            |
| 12               | provide (1) the second prediction if there is a hit and (2) the first prediction if there is a |
| 13               | miss.                                                                                          |
| 1                | 7. The processor of claim 6 further comprising:                                                |
| 2                | address hash logic coupled between the IP generator and the inputs of the SCBP                 |
| 3                | and LBHP logic to provide a plurality of index values to at least one of the SCBP and          |
| 4                | LBHP logic.                                                                                    |
|                  |                                                                                                |

| ( o | \t<br>\t | 1 |
|-----|----------|---|
|     |          | 2 |

1

2

3

4

5

6

3 4 5

1

3

8. The processor of claim 6 wherein the SCBP logic includes a bimodal predictor.

9. The processor of claim 6 wherein the LBHP logic includes a plurality of local branch history tables each to provide a tag and a taken/not-taken history associated with the tag in response to a hit, compare logic coupled to each of the plurality of tables to determine the hit/miss indication, history multiplexer coupled to each of the plurality of tables to provide the history for the hit, and combinational logic coupled to an output of the history multiplexer to provide the second taken/not-taken prediction.

10. The processor of claim 6 wherein the LBHP logic includes at least one local branch history table to provide a tag and a taken/not-taken history in response to a hit, the processor further comprising:

entry replacement logic to update a replacement field for a matching entry in the at least one table only if the first prediction is incorrect.

- 11. The processor of claim 6 further comprising:
- 2 an instruction fetch stage of a pipeline; and
  - an instruction decode stage of the pipeline, and wherein the prediction at the
- 4 output of the multiplexer is available when the address is being processed by an
- 5 instruction decode stage of a pipeline.

| ۲<br><b>)</b> 1    | 12. The processor of claim 11 wherein the decode stage is capable of                     |
|--------------------|------------------------------------------------------------------------------------------|
| 2                  | determining a target address of a branch instruction located at the address, the         |
| 3                  | processor further comprising                                                             |
| 4                  | control logic coupled to load the IP generator with the branch target address if an      |
| 5                  | output of the multiplexer indicates, for the address, that a branch is predicted to be   |
| 6                  | taken.                                                                                   |
| 1                  | 13. The processor of claim 6 wherein the address points to a cache line having           |
| 2 11 12 12 13      | a plurality of instructions.                                                             |
| اً.<br>1 <u>نا</u> | 14. An apparatus comprising:                                                             |
| .П<br>`42          | means for providing an address of at least one instruction;                              |
|                    | means for providing a first taken/not-taken branch prediction based upon the             |
|                    | current state of a state machine and responsive to the address;                          |
|                    | local branch history prediction (LBHP) logic having an input coupled to the              |
| 6                  | address providing means and capable of providing (1) a second taken/not-taken            |
| 7                  | prediction at an output responsive to the address resulting in a hit, and (2) a hit/miss |
| 8                  | indication for the address; and                                                          |
| 9                  | a multiplexer having an input coupled to the outputs of the first prediction             |
| 10                 | means and the LBHP logic and a select input coupled to receive the hit/miss indication   |
| 11                 | and in response provide (1) the second prediction if there is a hit and (2) the first    |
| 12                 | prediction if there is a miss.                                                           |
| 1                  | 15. The apparatus of claim 14 further comprising:                                        |



3

1

2

3

4

5

6

3 4 5

1

2

3

4

1

2

3

means for encoding the address to provide a plurality of index values to at least one of the first prediction means and the LBHP logic.

- 16. The apparatus of claim 14 wherein the LBHP logic includes a plurality of local branch history prediction tables each to provide a tag and a taken/not-taken history associated with the tag in response to a hit, compare logic coupled to each of the plurality of tables to determine the hit/miss indication, history multiplexer coupled to each of the plurality of tables to provide the history for the hit, and combinational logic coupled to an output of the history multiplexer to provide the second taken/not-taken prediction.
- 17. The apparatus of claim 14 wherein the LBHP logic includes at least one local branch history prediction table to provide a tag and a taken/not-taken history in response to a hit, the processor further comprising:

means for updating a replacement field for a matching entry in the at least one table only if the first prediction is incorrect.

- 18. The apparatus of claim 14 further comprising:
- means for fetching at least one instruction at the address; and
- means for decoding the at least one instruction, wherein at least one of the first and second predictions is available when the at least one instruction is being decoded.
- 19. The apparatus of claim 18 wherein the at least one instruction is a branch, the apparatus further comprising:
  - means for determining a target address of the branch; and

- means for fetching at least one instruction at the target address if at least one of
- 5 the first and second predictions indicates that the branch is to be taken.

